/**
*
Java Diagram Package; An extremely flexible and fast multipurpose diagram
component for Swing.
Copyright (C) 2001 Eric Crahen <crahen@cse.buffalo.edu>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package diagram;
import java.awt.Component;
import java.awt.geom.Rectangle2D;
import javax.swing.BorderFactory;
import javax.swing.DefaultCellEditor;
import javax.swing.JTextField;
/**
* @class DefaultFigureEditor
*
* @date 08-20-2001
* @author Eric Crahen
* @version 1.0
*
*
*/
public class DefaultFigureEditor extends DefaultCellEditor
implements FigureEditor {
/**
*
*/
public DefaultFigureEditor() {
this(new JTextField());
}
/**
*
*/
public DefaultFigureEditor(JTextField comp) {
super(comp);
setClickCountToStart(2);
}
/**
* This method is the first invoked when the editing process begins.
*
* @param Diagram surface that is being rendered upon
* @param Figure item to edit
* @param boolean
*
* @return suitable A Component that can render the given item is returned.
*
* @post the Component returned will most likey be changed, in that it will
* have been reparented & its bounds will be reset. Each time this Component
* is used this will happen, so generally it is not neccessary for the
* returned item to bother setting its own size.
*/
public Component getFigureEditorComponent(Diagram diagram, Figure figure, boolean isSelected) {
JTextField comp = ((JTextField)getComponent());
Object label = diagram.getModel().getValue(figure);
comp.setText(label != null ? label.toString() : "");
comp.setOpaque(true);
comp.setForeground(diagram.getForeground());
comp.setBorder(BorderFactory.createLineBorder(diagram.getBackground().darker()));
return comp;
}
public Object getCellEditorValue() {
return ((JTextField)getComponent()).getText();
}
/**
* Get the extended bounds for a Figure, these are bounds that a component should use
* to include a small area for decoration, such as different borders, or arrow heads
* that fall just outside the Figures normal bounds.
*
* This allows editors to occupy a space different from the figure when neccessary.
*
* @param Diagram
* @param Figure
* @param Rectangle2D reuse a rectangle
*
* @return Rectangle2D
*/
public Rectangle2D getDecoratedBounds(Diagram diagram, Figure figure, Rectangle2D rcBounds) {
FigureRenderer renderer = diagram.getFigureRenderer(figure.getClass());
return renderer.getDecoratedBounds(diagram, figure, rcBounds);
}
}